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Зачем я хотел писать тесты? 


фото: @1учКеопезаез1оп / ипзр!азй.сот 


< билайн 


Код будет проверять 

Наличие кода, который проверяет корректность моего кода 
после внесения изменений, позволит мне спать более 
СПОКОЙНО. 


Не надо все держать в голове 


Я не могу помнить обо всех особенностях системы, я человек, 
а не робот, мозг периодически очищает память. 


> билайн гы 3 ры = РНР Виза 


> билайн ^^ Д- р РНР Виза 


> билайн 5 > р РНР Виза 


> билайн ^ 6 - РА РНР Визэ!а 


фото: @аКзпаг_Чауе / ипзр!азП.сот 


> билайн г/м Би РН Кизза 


<? билайн 


Я предположил, что если я протестировал класс для работы с 
базой, то я могу стабить его в других классах, которые его 
используют. 


= РНРВизза 
2022 


<? билайн 


Стабы и моки 


Внешнее взаимодействие принято стабить или мокКать, то есть 
имитировать. 


р РНРВизза 
2022 


СТАБ ———_ верни мне вот это в этом 


методе этого класса 


<? билайн 10 - р РНРКозза 


<? билайн 


_910т Метод должен 


вернуть вот это и только 
один раз, не больше 


Пример: хеш пароля 


1 


РА РНР Нисза 
2022 


< билайн 


Не зависим от внешнего стенда, его режима работы, исключаем 
наше влияние на него, исключаем влияние сетевых событий: 
доступность, задержки. 


Ро 


р РНРВизза 
2022 


Рассмотрим класс для тестирования запросов 


5Е615->азз5е’ЕМа11 ( 
(пем Озегзбфоге())->Е1тпаВута (1) 


м м 


<? билайн 13 ^ = РНРВозза 


Теперь при тестировании другого класса — стабил базу 


// содержимое метода +езЕАаеВ в классе теста 


$зЕар = 5фаЬ: : маке (ОЧзегзб5фоге: :с1аз5$); 
$5Еар->мефроса ('Е1павута')->м111Вееагп (по11); 


$зегу1се = пем Озегбегутсе ($ за); 


со ч лая ьън 


$Т->ехресеТЬгомаЪ1е (пем ПБома1тпЕхсеретоп ( "Пользователь не найден"), 


10 $зегу1се->аа В (пем АапеПОзегРогм ( [ '1оч1п' => 'ризбса®'])); 


<? билайн - 14 - 


Еапсе1оп () { 


РА РНР Виза 
2022 


Результат начинал меняться от параметров. 


4 $эфаБ->мефеБоса (‘'зеевута' )->м111Вееагп (по11); 

5 $звар->мефроа ( 'Е1лпавутай1ЕВ Мате‘ ) ->м111Вефагп (ЕапсЕ1оп ($1а, $папте) { 
6 ТЕ ($1а == 2) { 

7 тетаЕй .... 

8 } 

9 хебагп пи11; 

10 }); 


<? билайн ^^ 15 ^^ РА РНРКозза 


Какие типы ошибок я не мог поймать в стабах? 


У" Ошибки с первичными ключами 


у Синтаксические ошибки 


У’ Ошибки, связанные с функциями 


< билайн > бе 


РА РНРВизза 
2022 


БД унас изначально пустая 


Ее нужно как-то наполнять для тестов 


<? билайн - 1/^ р РНРКозза 


< билайн 


Первоначальное состояние 


После каждого теста система должна возвращаться в 
первоначальное состояние, чтобы исключить влияние других 
тестов друг на друга. 


>. 18 = 


= РНРВизза 
2022 


Добавим фикстуру 


к. рчЬ11с ЕапсЕ1оп _Е1хвагез() { 

4 гебогп |[ 

= 'а5егз' => |[ 

6 'с1азз' => ОзегзЕ1хеаге: :с1а$$ 
г. ] 

8 ] 

9 } 

10 


<? билайн ^^ 19 -> р РНРКозза 


с1аз5 ОзегзЕтхЕаге { 
рир11с $моае1 = Озегз: :с1а$$; 
риб11с $Е11е = '/раВ/+о/Е11е/'; 


} 

// чзегз.рЬр 
Фикстура 
Заполняет нужные начальные гебагп |[ 
данные для теста. [ 


'1а'’ => 1, 
‘папе' => '4еупа11', 
'<фабаз$' => 1 


<? билайн 70 ^^ р РНРКозза 


Переносим данные из 
стабов в фикстуры 


Да, я перешел на базу, в целом 
стало терпимо управлять 
наборами данных. 


<? билайн 


о нлп 


15 
16 


'а5егз' => [ 


'с1азз' => ОЧзегзЕ1хфаге: :с1а$$, 


'ЁЕ1]1е' => 'аеЁао1*' 
], 
'пападегз' => [...], 
‘аааа’ => |... 1. 


пех Чзе’г$5Фоге ( 
У11 : :$арр->аь 


- 71 > 


р РНРВизза 
2022 


Когда подключалось не так много фикстур, все было хорошо. 


Со временем кол-во начинало расти, и я не мог разобраться, что 
используется для теста: 


о с каким статусом используются юзеры для теста? 


+ в файле фикстуры вижу полетуре = 1 -— что это? Шёл в модель... 


< билайн О в 


р РНРВизза 
2022 


Я хотел относительно быстро ПОНЯТЬ, ЧТО Происходит в тесте, если давно их 
не открывал. 


Например, это актуально было бы также и для новых разработчиков в команде. 


<? билайн 73 ^^ = РНРВозза 


Генерация данных 


оао 
шюноюочяю“оьрьоьъьън 


// метод сезфАяаеВ класса теста 


Зиз5ег = Озегсз: : сгеафе ()->аззегЕ$ауе(); 
$изе’г->а$51а1пИ1ЕБМапасег ( 

Змапацег = Мападегз: : сгеафе ()->ас+1уе() 
); 
баам1п = Аашлп: : сгеафе ( ) ->аззегЕбауе(); 
$баам1п->\м1ЕПРегт1$ топ (Реги1$51оп : :ргоЕ11еВоцее()); 


$Во1Аа1па = Но1А1па: : сгеафе ("ро1а #1") ->аззете5ауе (); 
$Во1а1па->аааМапасег ($тападзег); 


// вызов Чзегбегу1се->аоВ () 


< билайн г ОД 


= РНР Нисза 
2022 


Генерация данных 


Выглядеть стало более понятно, мне стало проще 
понимать, что происходит в тесте. 


В классах генераторов можно внутри использовать 
ЕаКег для рандомных данных. 


Кстати, в Гагауе| для этого используют фабрики данных. 


Но все равно было много тестов, частых правок.... 


< билайн О 


р РНРВизза 
2022 


Около года я писал тесты, а сложность увеличивалась... 


<? билайн г 76 ^^ РА РНРВозза 


Я понял, что что-то идет не так, 
и удалил папку тестов..... 
И тестировал ручками в браузере где-то полгода 


<? билайн 7 р РНРКозза 


Набирался сил, смотрел ютубчик, изучал материалы... 


<? билайн 78 = РНРВозза 


Метод белого ящика 


\мПКе Бох 
Для меня важными в итоге ) 


стали две концепции: 
Метод черного ящика 


(аск Бох) 


фото: @\озП|ерча / ипзр!азП.сог 


<? билайн 70 > р РНРКозза 


Белый ящик 


фото: @зхатапт / ипзр!азП.сог 


<? билайн 


Проверяем форматы дат, наличие записей в бд, наличие джобов в 


очередях, отправку почты, ключи в кеше ит.д. 


Что у нас все реализовывается корректно. 


248336 2250 пи/ 2400 9 


30 ^ 


д 
2022 


ЮКизэа 


Черный ящик 
Проверяем внешнее поведение: 


+ Поля формы можно заполнить, они подсвечиваются при 
ошибках, и кнопка оформления заказа активна при 
корректных полях и неактивна при некорректных. 


у Например, после регистрации мы находимся на странице 
профиля и видим текст приветствия. 


"т щ 


фото: @допоуап_уа!Ама / ипзр!азП.сог 


> билайн — 31 2ы р РНР Виза 


фото: @|оап / ипзр!азй.сог 


Как это происходит, через внешнее 
взаимодействие с другим сервером, работу с 
туза! или ро${9гез$ — это всё нас не интересует. 


< билайн к нь 


Что выбрать? 


После всей боли, что же я должен выбрать... 


Рассмотрим пример. 


фото: @рпоозмийпадаве / ипзр!азП.сот 


> билайн — 33 ы = РНР Виза 


При тестировании методом черного ящикау меня были 
случаи, что, например, сам статус в бд оказался другим и 
у нас ошибка в Те в контроллере, но все вроде работает. 


Или, например, дата создания не установилась, а в гриде 
она выводится, потому что не было проверки на пи! 


< билайн ‚ ЗД = 


фото: @)отузоп / ипзр!азП.сог 


р РНР Низ 
2022 


"Здесь был рйр и оставил эту надпись, но он уже мёртв" 


— доапа 


5) билайн р РНР Виза 


Давайте подойдем ближе к коду 


5) билайн — 35 Ры РА РНР Визэ!а 


Как я мог это тестировать? 


> 


Е "СФ о = 
| 
' 


и. 
е 
“ 
Сы - 


ПО У | Первый способ 


| 


Писал тест на каждый класс, 
который используется в реализации 
наших бизнес-требований. 


№ 
И " 9% ы-- 


. 


фото: @зсещзригасу / ипзр!а$П.сог 


> билайн — 36 вы р РНР Виза 


Какие это были классы 


1 с1аз$ ОгаегСопего11ег ехЕепа$ Сопёго11ег 

2 { 

3 рур11с ЕапсЕ1оп асЕ1опСгеаке() { 

4 $Еогм = пем СгеафеОгаегЕоги(); 

5 1Е ($Еогм->1Тоаа ( $+115->геацез*->роз$*()) && $Еогм->уа11ааее()) { 
6 1Е ($Еогм->зауе()) { 

7 гефагп $&015->геа1гесе ('зиссезз'); 

8 


} 
9 } 
10 гебагп $+015->гепаег ('1паех', сомрас*( 'ЁЕогт')); 
11 } 
12 } 


> билайн — 37 ы р РНР Виза 


Хотелось порой убить ноутбук 


фото: @зитрИсКу / ипзр!азВ.сог 


>“ билайн — 38 — в РН Кизза 


Второй способ 


Ро${-запрос на урл создания заказа с последующей 
проверкой состояния: 


#— 


ара = 1 


* 


ых 
АА 
. и 


У’ проверить наличие записи в бд 


З\у проверить поля заказа 
х проверить длину номера заказа 


У? проверить, что нас редиректнуло на 
некий урл заказа 


у \ = --- > т. © 5 е-ь 4 
ия еже ры А оны о дойжь, 
мир 24 ых. 24 


у зы ме ЧО ем, ных 
Ее авы 


фото: маеяат 5 у ия 


> билайн — 30 ы РНР Визэа 


фото: @атееп{тайту / ипзр!азП.сог 


< билайн 


Третий способ 


Поднять браузер и покликать форму: 


х форма заполняется 


7 поля подсвечиваются 
У кнопка активна 


УМУ происходит редирект на нужный урл 
после успешного оформления 


> 40 = 


Приходит новое требование 


Отправить уведомление в телегу менеджеру. 


<? билайн - ДЛ р РНРКозза 


фото: @гпузКепи$п / ипзр!азп.сот 


<? билайн 


Решил сделать через очереди: кидаю джобу и при 
обработке кидаю уведомление менеджеру. 


Что изменится? 


— 71 — = РНР Кизэа 


<? билайн 


В первом варианте дописываю тесты на 
новые классы 


// ОгаегСопего11ек 
1Е ($Еогм->зауе()) { 


У11 : : 5$ арр->ацеце->ризвВ ( 


пем МемОгаегооь (['1а' => $Еогип->дееМемогаегта()]) 
ЧЕ о реооиь 


); 


У11 : :5барр->+е1еда 
->зеп@(пем Меззаде ($Еогт->+ехЕМеззаче())); 


гебагп $+61$5->геа1гесе ('зоассезз'); 


>. 43 — 


РА РНРВизза 
2022 


Во втором дописываю 
проверки 


< билайн 


+ Создалась джоба 


7 Итоговое сообщение телеграма 
имеет нужный текст в нужном 
формате 


^^ ДД - р РНР Кизза 


я 


В третьем варианте, например, проверяю 
телеграм-менеджера или тестовый 
телеграм. 


< билайн ‚ 45 — 


РА РНРВизза 
2022 


г 


Рефакторинг 


<? билайн ^ 46 - РНРКозза 


Есть код 


с1азз Огае’гСопего11ег ехЕепа$ СопЕго11ег 
| 
ру11с ЕапсЕ1оп асЕ1опСгеаее() { 
$Еогм = пем СгеафеОгаегЕРоги(); 
1Е ($Еогм->1Тоаа ( $+61$->геачез*{->роз*()) && $Еогм->уа11Ааее()) { 
1Е ($Еогт->зауе()) { 
$)орЬ = пем Мемогаегдоь (['14а' => $Еогм->дееМемОгаегта()]); 
У11 : :барр->габЬ1+Оцепе->развВ ($705); 
гебагп $+61$5->геа1гес® ('зассез$'); 
} 
} 


гебагп $+61$->гепаег ('1паех', сомрас*('ЁЕогт')); 


<? билайн -4/-^ 


р РНРВизза 
2022 


Тимлид 
сказал переписать наш 
контроллер по-новому 


<? билайн 


с1азз$ Огае’Соп+го11ег ехЕепа$ СопЕго11ег 


{ 


ручБ11с Еапсё1оп асе1опСгеа*е() { 
$Еогм = пем СгеафеогаетгЕоги(); 


1Е ($Еогш->1оаа ($+615->геааез{->розе()) && $Еогм->уа11Чаее()) { 


гу { 
(пем М1ЕБТгапзас® тол ( 
пем Огаег5егут1се ( 
пем Огаег5Фоге (У11: :$арр->аЬ), 
пем Уа11Чафог(), 
пем ЕуепЕ01зраесвег(), 


пем Тгапзасе1опМапасчег (У11: : $арр->аЪ) 

) )->сгеафе ($Рогм); 
$+61$->5ассезз ("Заказ успешно оформлен") 
гефагп $&015->геа1гесе ('зассез$'); 

} саесь (РомалпЕхсере1опт $е) { 
$Е015->еггог($е); 

} 

} 


гееагп $&01$5->гепаег ('1паех', сопрасе( 'Ёогт')); 


. 48 — 


й Первый вариант 
Я убивал почти все классы и все 
писал по-новой 


& Второй и третий 


Ничего не менял 


<? билайн г Д9- р РНРКозза 


Я думал, зачем мне все это, пишу 
тест на сервисный ипк-класс и все 
ТИП-ТОП 


> билайн — 50 Ры РА РНР Визэ!а 


Но тогда я не покрывал следующий случаи: 


МАЕ тт /огаег/сгеае 


Напаег Напаег 


Еггог 
Напег 


/огаег/зиссе$$ 


> билайн г 51 > РА РНРВозза 


Используя второй и третий 
способы — покрываю. 


> билайн — 57 вы = РНР Виза 


< билайн 


Я сделал выводы: 


* 
* 


Надо помнить про стоимость такой изоляции. 


Речь про баланс, затраты, в том числе и моральные при 
первом написании тестов. 


Первым вариантом я повышаю стабильность работы, 
надежность. 


> 53 = 


р РНРВизза 
2022 


Изучая более подробно, что я сделал, выяснил, что: 


й Первый 


Опк-тесты 


й Второй 


Интеграционное тестирование 


х Третий 


Приемочное тестирование 


> билайн г БД - р РНР Виза 


Средним по затратам оказался второй вариант. 
Минимум кода в тестах, удобство при рефакторинге. 


о 


> билайн г 55 ^^ РА РНР Визэ!а 


Моя боль была в отсутствии баланса 


5) билайн г 56 -> р РНР Виза 


С чем я столкнулся дальше... 


> билайн м 0/-^ = РНР Виза 


Я начал фантазировать дальше 
Пользователь может создать заказ, менеджер его может подтвердить 


// метод сгеафе тесте ОгаегСез* 
$Т->амОпРаде ( [ ' /огаег/сгеаее']); 
$Т->5еекКезропзеСоае (200); 
$Т->зи 51 ЕРогм('#сгеафе-огаег', [ 
'Сгеафе0огаегЕогм' => |[ 
'паме' => 'РазрК1п', 
'рвопе’' => '....' 
] 
1); 
$Т->сапЕбее\уа11АаЕ1опЕггог$ (); 
$Т->зеетТпСиггепеОг1 ([ '/огаег/зассезз']); 
Е 


ыы в - 
шюмноюочям“иоиьроьоььън 


<? билайн . 58 -, 


р РНРВизза 
2022 


Менеджер его может подтвердить 


13 
14 $Т->атОпРацде ( [ '/аат1п/огаег/сопЁ1гм' ]); 


> билайн — 50 ы р РНР Виза 


По сути дальше я сталкиваюсь с проектированием кода, 


только уже для тестирования, чтобы было понятно, удобно. 


Я ввел понятие Вата щ и создал Раде-классы 
(подсмотрел в сторону РадеОЦес{ паттерна). 


<? билайн 60 - 


РА РНРВизза 
2022 


1 с1азз$ ОгаетРасче { 

2 ргофесфеа $$езфег; 

3 

4 раЬ11с ЕапсЕ1оп _ сопзЕгас® (РапсЕ1опТезеег $+езфег) { 

5 $+115->$езбег = 5$$езфек; 

6 } 

7 

8 риб11с ЕапсЕ1оп сгеафе (СгеафеОгаеграеабее $аафа) { 

9 $+615->+ез$ег->атОпРасще ( [ '/огаег/сгеаее' ]); 
10 $Е115->Еезфег->з5еевВезропзеСоае (200); 
ТЕ $&015->езфег->заЪм1+Роги('#сгеафе-огаег', $аафа->м1115аЪм1ЕРафа()); 
Те $Е115->$ез$ег->сапЕ5ееУа11Аае1опЕггог$ (); 
13 $+015->+езфег->зееТпСаггепОг1 ([ '/огаег/зиссезз']); 
14 } 
15 № 


> билайн ^ 61 - р РНР Виза 


рур11с ЕапсЕ1оп сгеафе (Гапс&1опа1Тезфег $Т, ОгаегРаде $разе) { 
Гане 
браче->сгеа+е (пех СгеафеО0гаегра+аб$е* ( 
'раше' => 'РазьК1п', 
'рвопе' => '....' 


)); 
#7 


о чп 


<? билайн и Бы 


р РНРВизза 
2022 


щи 


10 
12 


тэ 
14 


<? билайн 


$богаег = $раде->сгеафе(пем СгеафеОгаегра+абе* ( 
'паме' => 'РазрК1т', 
роет => а 


)); 


$Т->аз0зег ($тападзег); 
$раде->сопЁ1гм(пем СопЁЕ1гмОгаегра*абе* ( 


'1а' => $огаег->1а 


)); 


о 


р РНРВизза 
2022 


< билайн 


Снова фикстуры 


Выглядит очень интересно, я могу просто дергать роуты и 
создавать нужные нам данные, но у меня была ситуация, 
когда это было слишком долго. 


Проверить, отправился ли промокод после, например, 
оформления 1000-го заказа? 


<, 64 — 


р РНРВизза 
2022 


Я должен создать, потом подтвердить, потом 
смоделировать оплату — и так 1000 раз. 


№ 


> билайн г 65 - р РНР Виза 


< билайн 


Будет очень долго, проще будет использовать фикстуру либо 
отдельный класс, в котором я буду 1000 раз создавать заказ, но 
потом создам дамп сгенерированных данных для будущего 
теста на скидку. 


› 66 


р РНРВизза 
2022 


Давайте разберем тест с заказом более подробно 


5) билайн ^^ б6/- = РНР Виза 


Кода пока еще нет 


1 с1аз$ ОгаегСезе 

2 { 

3 рир11с Еапсё1оп сгеафе (ЕГапсЕ1опа1Тезеег $Т) { 
4 

5 } 

6 } 


> билайн — 63 Ры р РНР Виза 


4 $Т->атОпРадце ( [ '/огаег/сгеаее']); 


> билайн — 69 2ы р РНР Виза 


- $Т->зееВезропзеСоае(200); 


<? билайн ^^ /0^ р РНРКозза 


4 $Т->зари1еЕРоги('#сгеафе-огаег', | 
5 'СгеафеогаегтЕРогм' => |[ 
6 '‘папе' => 'РазрКлп', 
Оформляем заказ 7 ор 
8 о 
х ] 
10 ]); 
11 $Т->сапЕбееУа11Аае1опЕггогз (); 
12 $1Т->зееТпСиггепеОкг1 ( [ '/огаег/зиссезз']); 


<? билайн ^^ /|^ р РНРВозза 


4 $Т->азвзегеСочпе (1, $огаегз = Огаегз: : Езпа()->а11()); 
5 богаег = $огаег$[0]; 
6 $Т->аззегЕЕача1$ ('РазрКк1п', $огаег->папе); 


<? билайн |7 р РНРВозза 


Я заметил, что тесты почти отображают бизнес- 
требования и я могу писать тест до кода. 
Записывать ГЗ под диктовку со слов менеджера? 


<? билайн г /3 ^^ р РНРКозза 


фото: @]отузоп / ипзр!азй.сот 


<? билайн 


> 74 - 


Так это же вроде ТОО? 


р РНРВизза 
2022 


<? билайн 


$ 


Я сперва описываю требования, потом 
под эти требования пишу код, чтобы он 
заработал. 


> 7Б ^^ 


РА РНРВизза 
2022 


Когда приходит новое требование, я правлю 
тест, запускаю — он падает. 


Я правлю код, тесты проходят. 


<? билайн г /6б > р РНРКозза 


Так же, когда я уточняю требования, так же 
добавляю заранее граничные случаи: заказов 
нетв БД, один заказ и множество заказов. 


® 


<? билайн м/м р РНРВозза 


Если у меня случился баг, сперва пишу тест, 
который этот баг воспроизводит, и потом 


С правлю код. 


<? билайн г /8 ^^ р РНРКозза 


Когда приходит новое требование, я 
правлю тест, запускаю — он падает. 


1 // ОгаегСопеЕго11ег 

2 1Е ($Еогм->зауе()) { 

3 

4 У11 : :5$арр->ацепе->развВ ( 

5 пем МемОгаегооь (['1а' => $Еоги->дееМемогаегта()]) 
6 ‚, Е и неееретаиниь 

7 У11 : : $барр->+е1еда 

8 ` > эй Меззасе ( $Еоги->$ехеМеззаде())); 
9 гесагп $+61$->геа1гесе ('зиссезз'); 

10 

11 } 

12 


<? билайн ^ /9 > РА РНРКозза 


А как я мог проверить етай? 
у Как проверить, что ушло сообщение в очередь? 


$? Как проверить, что ушло сообщение в телегу? 


фото: @итто$зПо!аег / ипзр!аз$П.сог 


> билайн — 80 гы р РНР Виза 


Функции из коробки 


1 /**х 

2 х @уаг МеззадеТпеетРасе $теззаде 
с: 

4 Зпеззаде = $Т->дгаБГаз+бепаЕта11(); 
5 

<? билайн 


$Т->аззегЕАггауНазКеу ('зеп+@ета11.сом', $меззаде->дееТо()); 


>81 = 


р РНРВизза 
2022 


01-контейнер 


У11 : : $5 сопфалпег->5е651п91фоп (Те1едгамС11еп ::с1аз$, РЕапсЕтоп () {4 
гебагп пем Те1едгат5 а6С11еп*(); 


}) 


$Т->амОпРасде ( [ '/огаег/сгеаее']); 

$Т->зееВезропзеСоае (200); 

ГА зьве 

$Т->аззегЕСоцп* (1, $меззадез = У11: : $сопфа1лпег->де+ (Те1едгатС11еп+ : :с1аз5)->меззасдез () 
$Т->аззегЕЕаца13 ('зепае’г@пе11о.сом', $щеззасдез [ 0 ]->дефбепаег () ->деЕта11()); 


о ючпбюачакоьън 


> билайн — 87 Ро р РНР Виза 


Для отлова ошибок: 


1 У11: : $арр->апепе->оп (Очеце: :ЕУЕМТ АЕТЕКВК ЕВВОК, ЕапсЕтоп(ЕхесЕуепе $еуеп®) { 
2 Е№гом $еуепЕ->еггог; 


3 }); 


Сообщение ушло в очередь: 


1 5$ачече->оп (Очеце: :ЕУЕМТ АЕТЕВ РОЗН, ЕапсЕтоп (РАазрЕуепе $еуеп®) изе (&$сойп®) { 
2 рерач : : аеБачд (["ФоБ", Уаграмрег: : ацтрАз5Ег1 па ($еуепе->7]ор, 3)]); 

3 ТЕ (поа11 !== $сочп®) { 

4 $сойпЕ++; 

5 | 

6 }); 


> билайн — 83 Аы р РНР Виза 


- 


Пример проверки: 


1 /** 

2 * @уаг ОцепеЕг11е $апеце 

3 * / 

4 5ачеце = У11::$арр->ачеце сопегасфз; 

5 $сочпе = 0; 

6 $Т->афаспЕуепеОченеАЕ егРазвЬ ($апейе, $сопп®); 
а 

8 $Т->аззегЕЕача1$(1, $сойп®); 

9 5ачече->гап(0); 

0 $Т->аззегЕЕача1$(2, $сойп®); 


< билайн ‚84 — 


р РНРВизза 
2022 


Глобально: 


памезрасе Не1рег\Моаи1е; 


с1аз$ У112Моац1е ехфепаз$ У112 { 
рур11с Еапсё1оп _РеЕоге(ТезЕТпЕегЕасе $+ез%):уо1а { 
рагеп* : : БеГоге ($+ез%); 


$ачецеМмамез = аггау Кеуз (геда1ге . 'сопЁ19/ааецез.рВр'); 


Гогеасй ($апецемамез аз $алецемаме) { 
$Е615->аераадбесе1оп ("Опецез", "С1еаг $алецеМмате"); 
$ааепе = У11: : $арр-> { $ааецемате}; 
$ачеце->с1еаг(); 
$Е115->аерадбесе1олп ("Оцецез", "5её еггог Вапа1ег $ааецемапе"); 
$апеце->олп (Опепе: :ЕУЕМТ АЕТЕВ ЕВВОВ, ЕапсЕ1оп(ЕхесЕуепЕ $еуеп®) { 
ЕБгом $еуепе->еггог; 
}); 
} 


вн нвыынв ыы 
ю ючмяюиьфьюноюочяпоиьрььн 


$Е615->аерадбесе1оп ("Сасве", "С1еаг сасве"); 
У11 : :$арр->сасве->Е1аз1(); 


ых м 
о 


221 


> билайн — 35 Ры РНР Виза 


у № 1е5{5 
› М аза 
> № ошрш 


> 8 _5ирром 


в Арр 
. > бт 
Соаесерйоп ан 
Инструмент для тестирования > вв гипсНопа| 
Так исторически сложилось, что я его ны 
ИПИ 


стал использовать. 
9 _рос{$гар.рйр 


й сопзое.зиКе.ут| 
п. псНопа|.зиве.ут| 


п. ипК.зиКе.ут| 


> билайн — 36 гы р РНР Виза 


Пример конфига 
Например, содесерйоп.ут! 


асфог: Тезфег 
рооф5$гар: _рооф5егар.рпр 
раеп$ : 
фезЕз: сезез 
109: фез+5/ опёрие 
Чафа: +езЕ$/_АЧафа 
Ве1регз: +езе$/_зиаррог® 
зеёЕ1па3: 
шемогу 1111: 1024М 
со1ог5: фгае 
поа11ез: 
СОПТтО- 
ОЬ: 
Ап: "му5а1 :Во5&=аЬ; Абпаме=фез*" 
изег: "гооф" 
раззмога: "раззмога" 
рорич1афе: +гае 
с1еапир: Ёа15е 
Фи 
сопЁ19Е11е: 'сопЕ19/$езе.рЬр' 


<? билайн 


> 87 = 


Когда я набил руку на тестах, я просто перестал о 
них говорить, а сразу на них закладывал время. 


В среднем, они начали занимать 5-10% времени от 
самой задачи, но сколько плюсов. 


При этом бизнесу могу объяснить важность, как и 
вам объяснил. 


фото: @)аппегбоуб2 / ипзр!азВ.сот 


> билайн — 38 гы р РНР Виза 


< билайн 


Когда мне надо было что-то сделать, я начинал думать, как 
мне это протестировать, иногда, когда это было сложно — я 
вспоминал, что могу протестировать руками : О 


>. 89 = 
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Дизайн кода 


Когда я начал думать, как тестировать код, я понял, что можно изначально подумать, 
как будут называться наши функции и как их будут вызывать. 


Пример с хешером, допустим, пусть он будет 


статическим. 

1 с1аз$ РаззмогаНазвегТезЕ ехфепа$ \СоаесерЕ1оп\0п1* { 

2 

3 риур11с Еипсе1оп фезеНазп() { 

4 $Вазв = РаззмогаНазрег: : ВазВ ('раззмога', '56а251'); 
5 } 

6 

Г, 


<? билайн г 90 -^- р РНРКозза 


Можно сразу описать граничные условия 


2 $&615->аззегЕМофЕмруу ($Вазв); 
3 $Е6515->аззегЕМо+Еача1$ ($раз$, $Ваз1); 
4 $&615->аззегЕЬепаеВ (27, $Базь); 


<? билайн г 91 —> РА РНРВозза 


А будет ли он удобен, если я захочу использовать нативную библиотеку? 
Как это должно быть? 


РаззмогаНазр ег : : ВРазВ ('раззмога', '56а251', 'рЬрМае1уе!1Ь'); 


РаззмогаАНазтег : : ПазВВуМа*1уеРВрГ1Ь ('раззмога', '56а251'); 


пн 


РаззмогаНазтег : : рюрМаетуе ()->ВазвВ ('раззмога', '56а251'); 


<? билайн г 97 -> = РНРВозза 


Другая команда использует П!-контейнер, будет ли наш 
хешер удобен? 


Коллега решил замокать наш хешер, потому что он использует 
тяжелый алгоритм хеширования, которые выполняется около 20 
сек — надо выставить более простой. 


Дорогая операция. 
Надо убедиться, что хешер в коде вызывается один раз. 


< билайн 9 = 


Упс, ау нас статика. 
Конечно, можно использовать спец. либы, но все же. 
Думал я, статика ведь функция класса, а не объекта, и снова проектирование. 


$разрег = 5фаБ: : маке (РаззмогаНазцег: :с1аз$, | 
'разб' => 5еаЬ: : опсе () 


1); 


$ВазВ = (пем Озег())->Базь ($Вазпег, ‘'раззмога‘); 


шин 


<? билайн - 9Д- р РНРКозза 


Это навело на мысль, 
что разрабатывать "общий пакет" — не такая 
простая задача 


® 


<? билайн ^^ 95 ^^ РА РНРВозза 


На новом месте работы мои тесты были вне гита 


<? билайн 96 ^- р РНРКозза 


Потом я их добавил в гит, потом в с 
в качестве ознакомительной 
информации 


<? билайн 97 > = РНРВозза 


< билайн 


Когда команда увидела падающие 
тесты при обновлении либы, — 
начали ощущать от них пользу. 


Эта практика начала потихоньку 
распоространяться. 


„08 — 


р РНРВизза 
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< билайн 


Также это было удобно на пет-проекте или 
закрытой бета-версии, когда я еще был заряжен 
и мне надо быстро накидать новый функционал, 


но при этом не ломать предыдущий. 


— 00 — р РНР Кизэа 


фото: @тпегпатиге / ипзр!азП.сот 


< билайн 


А вдруг вас супруга/супруг попросят 
закодить, и у тебя баги или быстро надо 
будет накидывать функционал. 


Будет неприятненько... 


— 100 - 


$ 


Рекомендации, 
ВЫВОДЫ 


<? билайн 101 - = РНРРис5а 


Удобство 


Проще обновить ПО, фреймворк, язык 
Собираем новую сборку в докере и запускаем тесты 


В долгосрочной ускоряет разработку фич 
Вы пишете новый функционал и при запуске тестов 


понимаете, что ничего не сломали. Меньше багов в бэклоге. 


Тесты выступают почти как БТ 

Проще понять, "как должно работать" приложение на 
нескольких тестах, чем составлять цепочку работы по всем 
файлам. 


<? билайн 102 - 


фото: @поайБизсвег / ипзр!азП.сог 


р РНРВизза 
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Писать тесты до кода можно 
при определенной подготовке 


<? билайн ^ 103 - р РНРКозза 


Потребуется время, нужно 
попробовать 


* 


<? билайн 104 - = РНРРиз5а 


< билайн 


Это почти как привычка. 
Если не писали тесты, надо 
будет начать с малого, 


например, с простых ипКов. 


Этот этап нужно пройти. 


105 - 


РА РНРВизза 
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Начните с малого, установите 
содесерйоп, настройте, создайте 
тест 


< билайн - 106 -— = РНРРис5а 


Особенности содесерНоп 


х Для сопзо[е-тестов надо не забывать переконфигурировать 
\1!2 на конфиг сопзо[е 


$ При работе в функциональных тестах при переходе между 
контроллерами, Бос{$гар-файл лоадится только один раз 


<? билайн — 10/- 


= РНРВизза 
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Особенности содесерНоп 

& При переключении с веба на консоль и обратно — возникают ошибки 

х При тестировании апи через функциональные тесты, при появлении ошибки 
в апи в тестах будет отдаваться ехсерйоп, а не конечный ответ апи. 


Мы не покрываем тест с еггог Пап4егом. Лучше тестировать через 
приемочные, например, использовать РирВгом/зег (сип-запросы). 


< билайн ^ 108 - = РНРРиз5а 


Спасибо 


Надеюсь, после моего доклада те, кто не хотел писать тесты, 
получат надежду и начнут потихоньку пробовать, а те, кто писал, 
найдут для себя что-то новое. 


Волторнистый Артём 
телеграм — @ацетуон 


доклад — ПЁрз://\К.сс/сМ/ХИЦО 


Оценить доклад 


<) билайн 


р РНРВизза 
2022 


